/*
  Buttons
 */

.button {
  --hover-secondary: #b0d7f2;
  --hover-default: #b3b3b3;
  --hover-confirm: #0372c3;
  --hover-red: #feb6bf;
  --hover-red-primary: #c72837;
  --hover-orange: #ffd3b5;
  --warning-light-orange: #f8b588;

  @include H6;

  font-weight: 500;
  padding: 0.75rem 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  border-radius: 6px;
  width: 100%;
  transition: border-color 0.3s ease, background-color 0.3s ease;

  &--disabled,
  &[disabled] {
    cursor: auto;
    opacity: 0.5;
    pointer-events: none;
  }

  &__icon {
    display: flex;
    align-items: center;
    margin-right: 4px;
  }
}

.btn-secondary {
  color: var(--Blue-500);
  border: 1px solid var(--hover-secondary);
  background-color: var(--white);

  &:hover {
    border-color: var(--Blue-500);
  }

  &:active {
    background: var(--Blue-000);
    border-color: var(--Blue-500);
  }

  &--disabled,
  &[disabled] {
    opacity: 1;
    color: var(--hover-secondary);
  }
}

.btn-warning {
  color: var(--Orange-500);
  border: 1px solid var(--hover-orange);
  background-color: var(--white);

  &:hover {
    border-color: var(--Orange-500);
  }

  &:active {
    background: var(--Orange-000);
    border-color: var(--Orange-500);
  }

  &--disabled,
  &[disabled] {
    opacity: 1;
    color: var(--hover-orange);
  }
}

.btn-danger {
  color: var(--Red-500);
  border: 1px solid var(--hover-red);
  background-color: var(--white);

  &:hover {
    border-color: var(--Red-500);
  }

  &:active {
    background: var(--Red-000);
    border-color: var(--Red-500);
  }

  &--disabled,
  &[disabled] {
    opacity: 1;
    color: var(--hover-red);
  }
}

.btn-danger-primary {
  color: var(--white);
  border: 1px solid var(--Red-500);
  background-color: var(--Red-500);

  &:hover {
    border-color: var(--hover-red-primary);
    background-color: var(--hover-red-primary);
  }

  &:active {
    background: var(--Red-600);
    border-color: var(--Red-600);
  }

  &--disabled,
  &[disabled] {
    opacity: 1;
    border-color: var(--hover-red);
    background-color: var(--hover-red);
  }
}

.btn-default {
  color: var(--Grey-500);
  border: 1px solid var(--hover-default);

  &:hover {
    border-color: var(--Grey-500);
  }

  &:active {
    background: #fbfbfc;
    border-color: var(--Grey-500);
  }

  &--disabled,
  &[disabled] {
    opacity: 1;
    color: var(--hover-default);
  }
}

.btn-primary {
  color: var(--white);
  border: 1px solid var(--Blue-500);
  background-color: var(--Blue-500);

  &:hover {
    border-color: var(--hover-confirm);
    background-color: var(--hover-confirm);
  }

  &:active {
    background: var(--Blue-600);
    border-color: var(--Blue-600);
  }

  &--disabled,
  &[disabled] {
    border-color: var(--hover-secondary);
    background-color: var(--hover-secondary);
  }
}

.btn-link {
  @include H4;

  color: var(--Blue-500);
  cursor: pointer;
  background-color: transparent;

  &:hover {
    color: var(--Blue-400);
  }

  &:active {
    color: var(--Blue-600);
  }

  &--disabled,
  &[disabled] {
    cursor: auto;
    opacity: 1;
    pointer-events: none;
    color: var(--hover-secondary);
  }
}

.btn--large {
  min-height: 54px;
}

/**
  All Buttons styles are deviations from design guide
 */

.btn-raised {
  color: var(--primary-blue);
  background-color: var(--white);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
  padding: 6px;
  height: initial;
  min-height: initial;
  width: initial;
  min-width: initial;
}

.btn--first-time {
  @include H4;

  height: 54px;
  width: 198px;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.14);
  color: var(--white);
  font-weight: 500;
  transition: 200ms ease-in-out;
  background-color: rgba(247, 134, 28, 0.9);
  border-radius: 0;
}

button[disabled],
input[type="submit"][disabled] {
  cursor: not-allowed;
  opacity: 0.5;
}

.btn--rounded {
  border-radius: 100px;
  will-change: box-shadow;
  transition: box-shadow cubic-bezier(0.6, -0.28, 0.735, 0.045) 200ms;

  &:hover {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
  }

  &.btn-secondary {
    border: 1px solid var(--Blue-500);

    &--disabled,
    &[disabled] {
      border-color: var(--hover-secondary);
      color: var(--hover-secondary);
    }

    &:active {
      border-color: var(--Blue-600);
    }
  }

  &.btn-default {
    border: 1px solid var(--Grey-500);

    &--disabled,
    &[disabled] {
      border-color: var(--Grey-100);
      color: var(--hover-default);
    }

    &:active {
      border-color: var(--Grey-600);
    }
  }

  &.btn-danger {
    border: 1px solid var(--Red-500);

    &--disabled,
    &[disabled] {
      border-color: var(--Red-100);
      color: var(--Red-300);
    }

    &:active {
      border-color: var(--Red-600);
    }
  }

  &.btn-warning {
    border: 1px solid var(--Orange-500);

    &--disabled,
    &[disabled] {
      border-color: var(--warning-light-orange);
      color: var(--warning-light-orange);
    }

    &:active {
      border-color: var(--Orange-600);
    }
  }

  &.btn-primary {
    background-color: var(--Blue-500);

    &--disabled,
    &[disabled] {
      background-color: var(--hover-secondary);
    }

    &:active {
      background-color: var(--Blue-600);
    }
  }

  &.btn-danger-primary {
    background-color: var(--Red-500);

    &--disabled,
    &[disabled] {
      background-color: var(--Red-300);
    }

    &:active {
      background-color: var(--Red-600);
    }
  }
}
